<template>
  <div class="app-container">
    <!--查询表单-->
    <div class="search-div">
      <el-form label-width="70px" size="small">
        <el-row>
          <el-col :span="8">
            <el-form-item label="登录用户">
              <el-input style="width: 100%" v-model="searchObj.username" placeholder="登录用户"></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="操作时间">
              <el-date-picker
                v-model="createTimes"
                type="datetimerange"
                range-separator="至"
                start-placeholder="开始时间"
                end-placeholder="结束时间"
                value-format="yyyy-MM-dd HH:mm:ss"
                style="margin-right: 10px;width: 100%;"
              />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row style="display:flex">
          <el-button type="primary" icon="el-icon-search" size="mini"  @click="fetchData()">搜索</el-button>
          <el-button icon="el-icon-refresh" size="mini" @click="resetData">重置</el-button>
        </el-row>
      </el-form>
    </div>

    <!-- 表格 -->
    <el-table
      v-loading="listLoading"
      :data="list"
      stripe
      border
      style="width: 100%;margin-top: 10px;">

      <el-table-column type="selection"/>
      <el-table-column
        label="序号"
        width="70"
        align="center">
        <template slot-scope="scope">
          {{ (page - 1) * limit + scope.$index + 1 }}
        </template>
      </el-table-column>
      <el-table-column prop="username" label="登录账号" width="180" />
      <el-table-column prop="ipaddr" label="登录IP地址" />
      <el-table-column prop="tag" label="状态" width="100">
        <template slot-scope="scope">
          <el-tag :type="scope.row.status === 1 ? 'primary' : 'danger'" disable-transitions>{{ scope.row.status === 1 ? '成功' : '失败' }}</el-tag>
        </template>
      </el-table-column>

      <el-table-column prop="msg" label="提示信息" />
      <el-table-column prop="createTime" label="创建时间" />
    </el-table>

    <!-- 分页组件 -->
    <el-pagination
      :current-page="page"
      :total="total"
      :page-size="limit"
      style="padding: 30px 0; text-align: center;"
      layout="total, prev, pager, next, jumper"
      @current-change="fetchData"
    />

  </div>

</template>

<script>
import api from '@/api/system/sysLoginLog'
export default {
  data(){
    return{
      listLoading:true, //数据是否正在加载
      searchObj:{}, //查询表单对象
      createTimes:[],
      page:1, //默认页码
      total:0,  //数据库中的总记录数
      limit:10, //每页显示记录数
      list:null
    }
  },
  created() {
    this.fetchData()
  },
  methods:{
    //加载日志列表数据
    fetchData(page=1){
      this.page=page
      if(this.createTimes && this.createTimes.length===2){
        this.searchObj.createTimeBegin = this.createTimes[0];
        this.searchObj.createTimeEnd = this.createTimes[1];
      }
      api.getPageList(this.page,this.limit,this.searchObj).then(response=>{
        this.list=response.data.records;
        this.total=response.data.total;

        //数据加载并绑定成功
        this.listLoading=false;
      })
    },
    //重置查询表单
    resetData(){
      this.searchObj={};
      this.createTimes=[]
      this.fetchData()
    }

  }

}
</script>

<style scoped>
.search-div {
  padding:10px;border: 1px solid #EBEEF5;border-radius:3px;
}
.tools-div {
  margin-top: 10px;padding:10px;border: 1px solid #EBEEF5;border-radius:3px;
}
</style>
